$(function () {
  // 导入layui
  var layer = layui.layer;

  // 1.1 获取裁剪区域的 DOM 元素
  var $image = $("#image");
  // 1.2 配置选项
  const options = {
    // 纵横比
    aspectRatio: 1,
    // 指定预览区域
    preview: ".img-preview",
  };

  // 1.3 创建裁剪区域
  $image.cropper(options);

  //   为上传按钮绑定点击事件
  $("#btn_change").on("click", function () {
    // 就是当点击上传按钮时，模拟点击了文件上传的地方。
    $("#file").click();
  });

  // 为文件选择框绑定change事件
  $("#file").on("change", function (e) {
    // 获取用户上传的文件
    var filelist = e.target.files;
    console.log(filelist);
    if (filelist.length === 0) {
      return layer.msg("请先选择上传的图片");
    }

    // 开始处理图片
    //       1.拿到用户选择的文件
    var file = e.target.files[0];
    //   2 .将文件，转化为路径
    var newImgURL = URL.createObjectURL(file); //把文件传入进去
    //  3.重新初始化裁剪区域
    $image
      .cropper("destroy") // 销毁旧的裁剪区域
      .attr("src", newImgURL) // 重新设置图片路径
      .cropper(options); // 重新初始化裁剪区域
  });

//   为确定按钮绑定点击事件
$('#btnUpload').on('click',function(){
    // 1.先拿到用户裁剪后的头像
    
    var dataURL = $image
      .cropper('getCroppedCanvas', { // 创建一个 Canvas 画布
        width: 100,
        height: 100
      })
      .toDataURL('image/png')       // 将 Canvas 画布上的内容，转化为 base64 格式的字符串

    // 2.调用接口，把头像上传到服务器上面
    $.ajax({
        method:'POST',
        url: "my/update/avatar",
        data: {
            avatar:dataURL
        },
        success: function (res) {
            if(res.status!==0){
                return layer.msg('用户更换头像失败！')
            }

             layer.msg('用户更换头像成功！')
              // 调用父页面方法重新渲染用户头像和信息
              window.parent.getuserInfo()
        }
      
    });
})
});
